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CROSS-REFERENCE TO RELATED APPLICATION 

This application claims priority of U.S. Provisional Application No. 
1 0 60/2 1 6,797, entitled " INTERACTIVE DATA TRANSMISSION SYSTEM/ 
filed on July 7, 2000, which is hereby incorporated by reference for all 
purposes. 

This application is related to Docket No. NEV1P001, U.S. 

Application No. filed on the same day, and entitled 

1 5 " INTERACTIVE DATA TRANSMISSION SYSTEM." 



20 Background of the Invention 

1. field of the invention 

The present invention relates generally to real-time data transmission 
across a network. More particularly, the present invention relates to real-time 
transmission of data and interactive modification of the data transmitted 
25 across a network in response to a request received from a network device over 
the network. 
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2. DESCRIPTION OF RELATED ART 

A popular pasttime in today's entertainment-oriented society is 
watching movies. In fact, many movie fanatics have acquired elaborate home 
entertainment systems solely for this purpose. However, for those individuals 
5 who decide to spend their Saturday night at home with a movie, there a 
limited number of options available to them. 

Traditionally, movie goers who prefer to watch movies in the privacy 
of their own homes rent videos from a local video rental store. However, the 
video rental process is a time-consuming one, requiring the movie viewer to 

1 0 travel from his or her home merely to obtain the desired video. Of course, 
even with the obvious disadvantages associated with the video rental process, 
many still find this desirable since they can watch the movie as many times as 
they want, and they may pause, rewind, fast forward, and re-start the movie at 
their own convenience. 

15 In view of the disadvantages associated with the conventional video 

rental process, pay-per-view is a viable option, particularly in hotels which 
often do not offer video rental services to its guests. Through the pay-per- 
view option, it is possible to select a video as well as view the video from the 
privacy of home or a hotel room. However, the movie choices typically 

20 offered to movie viewers by such cable providers are limited. Moreover, the 
pay-per-view option does not offer the advantages of a standard VCR. More 
particularly, the pay-per-view option does not allow a user to pause, rewind, 
fast forward, or re-start a movie once it has started. In addition, the available 
viewing times are typically set and therefore cannot be selected by a user. 
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Physical tapes are also used for a variety of purposes other than 
viewing movies. For instance, in Asian countries, karaoke is a popular 
pastime. A traditional karaoke business is commonly run with a central 
control room connected to multiple listening stations. The control room 
5 contains a machine associated with each listening station to enable a desired 
tape to be played and routed to the listening station (e.g., via a coaxial cable). 
When a karaoke participant in one of the listening stations requests a 
particular karaoke song, the appropriate tape is physically inserted into the 
machine connected to the listening station. The karaoke tape is then played 

10 and routed to the listening station connected to this machine. 

The existing karaoke model is undesirable in a variety of ways. Since 
a machine capable of playing karaoke tapes is required for each listening 
station, the existing karaoke system often requires numerous machines. Since 
these machines are not automated, it is necessary to employ personnel that 

15 will be available to operate the machines. Due to the expense associated with 
acquiring and maintaining numerous karaoke machines and associated 
personnel, a traditional karaoke business is far from inexpensive to operate. In 
addition, it is typically necessary to maintain multiple copies of songs that are 
popularly requested in order to be able to fulfill the same song request when it 

20 is received from more than one listening station. Moreover, since multiple 
copies are often retained for these popular selections, the cost of maintaining 
an adequate inventory as well as storage space to store these copies increases 
the cost of such a karaoke business. In addition, the quality of a physical 
medium such as a video tape deteriorates over time. Moreover, since the 
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karaoke tapes must be loaded and unloaded by humans, this type of system is 
susceptible to human error. As a result, the incorrect tape may be loaded or 
there may be a substantial delay between songs while the personnel are 
locating or changing the tapes. Thus, it is impossible for a karaoke participant 
5 to predict the time that a selected song will start. Similarly, it is impossible to 
predict the delay between songs that are loaded consecutively into the karaoke 
machine. It is also important to note that the karaoke singers in the listening 
stations do not have access do the machine associated with their private 
listening station. Thus, once a karaoke tape has been inserted, karaoke 

10 participants cannot interactively control their individual karaoke experience. 

In view of the above, it would be desirable if a system could offer the 
interactive nature of a VCR without the limitations and conveniences 
associated with a VCR. In addition, it would be beneficial if a user were 
provided a wide range of choices previously unavailable to a VCR or pay-per- 

15 view user. 
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Summary 



The present invention enables data to be transmitted over a network 
from a server to a client device such as a set-top box. This may be 
accomplished via a single local server as well as via multiple staged servers, 
5 such as from a central server via the local server. For instance, the central 
server may be associated with a web site on the Internet. In addition, once 
initiated, data flow may be modified and controlled interactively by the user. 
Moreover, a file may be loaded from the central server to a memory associated 
with the local server. This loading process may be performed in combination 
10 with data transmission upon initiation by a user (e.g., via a web browser) or by 
the local server when a requested file is not accessible to the local server. 
Alternatively, it may be desirable to load a file independently from the data 
transmission process. 

In accordance with one aspect of the invention, a first network device 
15 such as a set-top box may interactively control data flow from a second 
network device such as a server to the first network device. A control 
command indicating a desired modification to the flow of data from the 
second network device to the first network device is received at the first 
network device. The first network device sends a control command to the 
20 second network device. When the second network device receives the control 
command, the second network device modifies the flow of data from the 
second network device to the first network device in response to the control 
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command. The first network device then receives a modified flow of data 
from the second network device to the first network. This process may 
similarly be performed across multiple staged servers rather than by a single 
local server. 

5 Modification to the flow of data may be accomplished by modifying a 

data stream in a variety of ways. For instance, modification may include 
initiating transmission of a data stream, pausing transmission of a data stream, 
advancing transmission by a single frame, modifying the speed of 
transmission of data, and modifying the source of the data being transmitted 
10 (e.g., file and/or file location). Such a modification to the flow of data 

between network devices may be initiated by a user via an input device such 
as a mouse, keyboard, or remote control device. 

In accordance with another aspect of the invention, a user may select 
one or more files from which data is to be transmitted over a network from a 

15 network device such as a server to another device such as a set-top box. Each 
of the files may include video data and audio data as well as other digital data. 
For instance, each file may include a movie or a karaoke video. The user may 
select via the set-top box one or more of a plurality of files associated with the 
server. In addition, the user may specify an order of transmission of the 

20 selected files. Information identifying the selected files as well as the 

specified order of transmission may then be sent from the set-top box to the 
server. Data stored in these files may then be transmitted from the server to 
the set-top box in the order of transmission. 
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In accordance with another aspect of the invention, the present 
invention enables transmission of data to be billed within a multiple site 
system such as a hotel. More particularly, it is possible to bill a guest each 
time a movie or karaoke song is played (i.e., transmitted from the local 
5 server). Moreover, the hotel may wish to bill the guest an additional amount 
when the requested selection is transmitted from the central server over the 
Internet to the guest's hotel room (e.g., when the user accesses the central 
server via a web browser). Of course, it may be desirable to bill a guest once 
(e.g., when the associated file is loaded from the central server to the local 
10 server), allowing the guest to view the selection multiple times. 
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Brief Description of the Drawings 



The invention, together with further advantages thereof, may best be 
understood by reference to the following description taken in conjunction with 
the accompanying drawings in which: 

5 

FIG. 1 is a block diagram illustrating an exemplary system in which 
the present invention may be implemented in accordance with an embodiment 
of the invention. 

FIG. 2 is a block diagram illustrating an exemplary set-top box board 
10 layout that may be used to implement the present invention. 

FIG. 3 A is an exemplary screen shot that may be presented to a user 
upon start-up. 

FIG. 3B is an exemplary screen shot illustrating the selection of 
karaoke songs and/or movies to be transmitted in accordance with the present 
15 invention, 

FIG. 4 is an exemplary layout of a remote control that may be used to 
implement the present invention. 

FIG. 5 is a process flow diagram illustrating a method of playing a 
movie or karaoke selection in accordance with an embodiment of the 
20 invention. 

FIG. 6 is a process flow diagram illustrating a method of processing a 
user's voice input in accordance with an embodiment of the invention. 
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FIG. 7 is a process flow diagram illustrating a method of pausing a 
movie or karaoke selection in accordance with an embodiment of the 
invention. 

FIG. 8 is a process flow diagram illustrating one method of stepping 
5 transmission of data in accordance with an embodiment of the invention. 

FIG. 9 is a process flow diagram illustrating one method of reducing 
the speed of data transmission to the set- top box in accordance with one 
embodiment of the invention. 

FIG. 10 is a process flow diagram illustrating a method of initiating or 
10 resuming the transmission of data in accordance with one embodiment of the 
invention. 

FIG. 1 1 is a process flow diagram illustrating a method of selecting 
data files to be transmitted via a menu in accordance with one embodiment of 
the invention. 

15 FIG. 12 is a process flow diagram illustrating one method of initiating 

the transmission of data associated with a next selected video in accordance 

with one embodiment of the invention. 

FIG. 13 is a process flow diagram illustrating a method of performing 

a seek in accordance with an embodiment of the invention. 
20 FIG. 14 is a process flow diagram illustrating one method of 

processing data received by the set-top box in accordance with one 

embodiment of the invention. 
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Detailed Description of the Preferred 



Embodiments 

In the following description, numerous specific details are set forth in 
5 order to provide a thorough understanding of the present invention. It will be 
apparent, however, to one skilled in the art, that the present invention may be 
practiced without some or all of these specific details. In other instances, well 
known process steps have not been described in detail in order not to 
unnecessarily obscure the present invention. 

10 With the recent advancement of digital technology, the way 

information flows and data are exchanged have taken a new direction. With 
the aid of video compression and decompression technology, digitized audio 
and video data can now be transmitted live across cities, states, and countries. 
Moreover, network bandwidth continues to increase through the introduction 

15 of fast Ethernet, cable modem, Digital Subscriber Line (DSL), variations of 
DSL (xDSL), and Gigabit Ethernet. DSL service enables the transmission of 
data at rates up to 6.1 megabits (millions of bits) per second, enabling 
continuous transmission of motion video, audio, and even 3-D effects. 
Accordingly, real-time video transmission which requires high bandwidth is 

20 now feasible. 
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Through the use of the present invention, files such as movies and 
karaoke videos may be downloaded to a local server and streamed to one or 
more client devices (e.g., set-top boxes). In addition, interactive control of the 
streamed data is made available through the set-top boxes. Accordingly, the 
5 present invention provides the traditional advantages of a conventional video 
recorder without the restrictions or limitations of a video recorder. 

FIG. 1 is a block diagram illustrating an exemplary system in which 
the present invention may be implemented in accordance with an embodiment 
of the invention. The present invention is implemented in a network such as a 

1 0 local area network (LAN), which may be further coupled to a wide area 

network (WAN) such as the Internet. Within the network, one or more local 
servers 102 are used as the video-streaming server. Moreover, the local 
server(s) 102 may also be used as the content storage server that is capable of 
storing a plurality of files. One or more associated file servers 104 are used 

15 for user account management, content management, billing information, web 
server, firewall, and all other non-streaming related services. In addition, an 
equivalent central file server may be established at the central site which 
monitors and communicates with all the remote file servers. In order to 
decrease the costs associated with the local server 102 and limit the number of 

20 files available for transmission to each client, it may be preferable to use a 
suitable memory for storing approximately twenty files (e.g., karaoke files or 
movie files). However, this configuration is merely exemplary and a memory 
with a greater capacity may be implemented. These files may be supplied 
initially as well as downloaded from another server on the network, as well as 
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from the Internet. The local server 102 is adapted for being coupled (e.g., via 
an Ethernet switch 106) to a plurality of devices 108 (e.g., set-top boxes) that 
are each configured to transmit a control command to the local server 102 to 
control the initiation and flow of data associated with a particular file to the 
5 requesting device 108. In addition, each of the devices 108 is capable of 
providing video and audio signals to associated monitors or televisions 110 
when they are received from the local server 102. 

Through each device 108, a client may initiate the transmission of data 
associated with a specified file via the local server 102. In addition, once 

1 0 transmission of data is initiated, it may be desirable to interactively control the 
transmission of data from the local server 102. When the requested file is not 
available to the local server 102, the local server may access a central server 
112 over the Internet via an Internet Service Provider (ISP) 114. The central 
server 112 preferably has a vast data store of files in an associated memory. 

1 5 Alternatively, the client may independently download a requested file from 
the central server 1 12 via a web browser independently of transmission of the 
associated data to the client. For instance, when the user wants to watch a 
video that is not available on the local server, the user may access the central 
server and select one of a plurality of listed videos by clicking on the desired 

20 title(s). The central server 112 may then send the file to the local server 102 
for storage in the file server 104 and/or transmission to a requesting client. It 
is important to note that each client device 1 08 and the local server 1 02 
preferably perform authentication prior to establishing a communication link. 
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When a file is transmitted from the central server 1 12 to a client via the 
local server 102, the transmission and interactive control of the transmitted 
data may be performed in a manner to enable real-time streaming and 
therefore instantaneous access to the data by a requesting client. 
5 Alternatively, there may be a small or considerable delay, depending upon the 
transmission medium that is used. For instance, the transmission medium 
used to transmit data from the central server 1 12 to the local server 102, and 
from the local server 102 to each device 108 may include a traditional 
transmission medium such as a cable modem connection. In a WAN setting, 

10 bandwidth cannot be guaranteed at a sustainable rate to support real-time 

broad-band video streaming. Thus, it is important to note that the benefit of a 
the local server 102 in a LAN setting is to provide sustainable bandwidth to 
guarantee uninterrupted real-time video streaming. 

Traditional phone service transmits an analog signal which is 

15 converted into digital information by a modem. However, the maximum 
amount of data that may be received using an ordinary modem is currently 
approximately 56 Kbps. In contrast, with various xDSL technologies, it is 
possible to receive data at rates of well over one million bits per second 
(Mbps), enabling continuous transmission of motion video, audio, and 3-D 

20 effects. For example, current ADSL standards contemplate data receive rates 
on the order of 6Mbps. VDSL proposals contemplate data receive rates on the 
order of 25 or 50 Mbps. Thus, the delay involved in transmission of the 
requested data may be minimized through the use of a Digital Subscriber Line 
(DSL) or variations of DSL (xDSL). As a result, video quality is improved. 
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Moreover, since multiple devices 108 may be coupled to the central server 
112 through a single Digital Subscriber Line via the local server 102, each 
client need not individually obtain DSL service. In this manner, the cost to 
the consumer is considerably reduced while enabling the consumer to 
5 interactively control data transmission via the central server 112 with 
approximately instantaneous access. 

The present invention may be used by a business such as a hotel to 
enable multiple rooms to access a local server maintained by the hotel. Since 
the local server is maintained by the hotel, the hotel may wish to bill a guest 

10 each time a movie or karaoke song is played (i.e., transmitted from the local 
server 102 to a client device 108). Moreover, the hotel may wish to bill the 
guest an additional amount when the requested selection is transmitted from 
the central server over the Internet to the guest's hotel room (e.g., when the 
user accesses the central server via a web browser). Of course, it may be 

15 desirable to bill a guest once (e.g., when the associated file is loaded from the 
central server to the local server) while allowing the guest to view the 
selection multiple times. 

Billing information may be obtained in a variety of ways. For 
instance, billing information associated with the hotel room may be 

20 automatically obtained. As another example, billing information such as 
credit card information may be obtained from the user upon selection of a 
video. As yet another example, a smart card reader may be provided to enable 
the user to charge room services to his or her smart card. 
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As described above with reference to FIG. 1, multiple client devices 
108 may be coupled to a single local server 102. In accordance with one 
embodiment of the invention, a client device 108 may be implemented in the 
form of a set-top box. A set-top box is a device that enables a television set to 

5 become a user interface to the Internet and also enables a television set to 
receive and decode digital television broadcasts. More particularly, a set-top 
box is used by television viewers to receive digital broadcasts via an analog 
television set. A set-top box typically includes a Web browser stored in a 
memory in the set-top box, enabling a television user to access the Internet. In 

1 0 addition, a typical digital set-top box contains one or more microprocessors 
for running the operating system and for parsing an MPEG transport stream. 
A set-top box also includes RAM, an MPEG decoder chip as well as other 
chips for audio decoding and processing. In addition, a set-top box may 
contain a hard drive for storing recorded television broadcasts, for 

1 5 downloaded software, and for other applications. Similarly, a DVD drive may 
be used to enable the set-top box to access a variety of files. 

FIG. 2 is a block diagram illustrating an exemplary set-top box board 
layout that may be used to implement the present invention. In one 
embodiment, the set-top box board implements a standard Ethernet 

20 implementation and therefore includes a lOBaseT Interface 202, an Ethernet 
controller 204, an EEPROM 206 for storing an IP address associated with the 
set-top box board, and SRAMs 208, 210 for storing data obtained from the 
network (e.g., Internet). In addition, the set-top box includes a CPU 212 for 
running the operating system and for parsing an MPEG data stream. In 
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addition, a flash EPROM 214 may store software for drivers and other 
instructions necessary to implement the present invention. Moreover, this 
client software that is programmed into the flash EPROM 214 may be updated 
through the local server at any time for feature enhancement. System memory 
5 216 (e.g., DRAM) is available for use by the CPU. In addition, EPLD 218 is 
adapted for routing signals among components, thereby providing the 
appropriate combinational logic for the set-top box. MPEG decoder 220 is 
provided for decompressing video and audio data received in the compressed 
data received by the set-top box. DRAM chips 222, 224, 226, 228, and 230 

10 are provided for storing video data for the MPEG decoder 220. 

After the video and audio data is decompressed by the MPEG decoder 
220, the decompressed audio and video signals are processed separately. The 
decompressed video signal is then sent from the MPEG decoder 220 to a 
video encoder 242 to convert the digital video signal to an analog signal. The 

15 analog video signal is then output at a video input/output 244. The 

decompressed audio signal is sent from the MPEG decoder 220 to digital-to- 
analog converter 236 and output via stereo output 238 and therefore through 
an amplifier (not shown). 

In accordance with one embodiment, the set-top box includes karaoke 

20 capabilities. Thus, in addition to the data (e.g., karaoke file) received from the 
network, one or more microphone inputs 23 1 and 232 are provided to enable 
users to sing along with a karaoke selection. In the embodiment shown, two 
microphone inputs are supported, although it should be appreciated that any 
desired number of microphones may be provided. When a karaoke singer 
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sings into a microphone, the audio signal is processed by an analog to digital 
converter 233. The digital audio signal is then sent to a karaoke audio 
processor 234. For instance, the karaoke audio processor 234 may be a digital 
karaoke audio processor such as model MED25102 available from Medianix 
Semiconductor, Inc., located at 100 View Street, Mountain View, California 
94041 . The digital audio signal processed by the karaoke processor 234 is 
then sent to digital-to-analog converter 236 and output via stereo output 238. 
In addition, a DRAM chip 240 is available for storing audio data for the 
karaoke processor 234. A standard audio input 246 is also provided. In 
addition, an infra-red interface controller (not shown) may be provided to 
enable communication with a remote control device. 

In accordance with one embodiment, the set-top box is capable of 
switching between NTSC and PAL signals for world-wide adoption and 
compatibility. In addition, to implement a karaoke system, user interfaces in 
different languages may be provided by the set-top box. Similarly, files 
encoded with sound tracks in multiple languages may be provided at the local 
server to enable a sound track in a particular language to be selected at the set- 
top box. 

FIG. 3 A is an exemplary screen shot that may be presented to a user 
upon start-up. As shown, an initial screen 302 may be displayed which 
indicates one or more selections which may be input by a user. For instance, 
at start-up, a default selection type 304 may be presented to the user. More 
particularly, the selection type 304 of a file to be transmitted may be, for 
example, "karaoke" or "movie" . Thus, the default selection type 304 may be 

Attorney Docket No. NEV1P002/SDB/ERH PATENT 



17 



"karaoke" , as shown. In addition, the user may indicate a particular selection 
306 associated with the selection type 304. As shown, a number, title, or 
other mechanism may be used to identify each selection. 

FIG. 3B is an exemplary screen shot illustrating the selection of 
karaoke songs and/or movies to be transmitted in accordance with the present 
invention. Once the user has entered one or more selections, a TV screen or 
monitor 308 after all selections are entered is displayed. Thus, the selection 
type 310 may be "movie" or "karaoke", as shown. In addition, each 
selection 312 is identified numerically in accordance with a pre-selected set of 
selections available to the user. For instance, a manual may be provided to the 
user identifying the selections available to the user. 

As described above, the user sends control commands to the set-top 
box indicating desired modifications to the flow of data to the set-top box. In 
accordance with one embodiment, these control commands are sent to the set- 
top box via an infra-red remote control. FIG. 4 is an exemplary layout of a 
remote control that may be used to implement the present invention. A 
TV/VIDEO key 402 enables a user to toggle between a television and video 
mode. In addition, a NEXT key 404 stops the current video (e.g., movie or 
karaoke) and starts the next video selected. An ENTER key 406 enables a 
user to enter a number of key strokes. In addition, an NTSC/PAL key 408 
enables a user to switch between NTSC and PAL mode, as described above. 
A RESET key 410 reboots the set-top box. A VIEW/MENU key 412 enables 
a user to view a video after all karaoke or movie selections are entered. 
During video play, when the VIEW/MENU key 412 is toggled, a menu screen 
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is displayed to enable the user to add or edit the video selections. The user 
may then toggle the VIEW/MENU key 412 an additional time to start playing 
the current video selection. Number keys 0-9 413-430 may be used to identify 
video titles. Arrow keys 432-438 move the cursor up, down, right or left to 
enable a user to enter or modify selections. 

Various control keys are provided to initiate or modify the flow of data 
to the set-top box. When a PLAY key 440 is pressed, a selected video (e.g., 
movie or karaoke selection) is played at normal speed from either a PAUSE, 
STEP, or SLOW mode, each of which will be described in further detail 
below. In addition, in accordance with one embodiment, a percent video 
played indicator is displayed on the screen to indicate the amount of the video 
that remains to be transmitted. When a SLOW key 442 is pressed, the video 
speed is slowed (e.g., to one-half normal speed). The PLAY key 440 may 
then be pressed to resume to normal speed. Similarly, when a PAUSE key 
444 is pressed, the video is paused until the PLAY key 440, the SLOW key 
442, or a STEP key 446 is pressed. Once the STEP key 446 is pressed, the 
video is advanced by one frame at a time. 

Rather than viewing the entire video, the user may wish to view only 
specific portions of the video. When a SEEK key 448 is pressed during video 
play, the user may select a percentage of the video file to jump to. The video 
then jumps to that location and begins to play starting from that location. The 
seek location may be any location in the video file. Accordingly, the seek 
function may operate in forward or reverse. 

Attorney Docket No. NEV1 P002/SDB/ERH PATENT 



19 



In addition to video control keys described above, karaoke control 
keys are provided to enable the user to modify the audio signal associated with 
the karaoke music and/or the user's voice. The key functions may be 
implemented through the use of a conventional karaoke audio processor such 

5 as karaoke audio processor MED25102 available from Medianix. Various 
keys are provided on the remote control to implement various functions 
available in a karaoke processor. For instance, KEY- 450 decreases the key of 
the music, KEY + 452 increases the key of the music, KEY N 454 returns the 
key of the music to neutral, VOL + 456 increases the microphone volume, 

10 VOL - 458 decreases the microphone volume, ECHO + 460 increases 
microphone echo, and ECHO - 462 decreases microphone echo. When 
FADER 464 key is pressed, the vocal portion of the music is silenced. PITCH 
466 changes the pitch of the karaoke singer's voice that is received through 
the microphone by shifting the pitch one semi-note with each depression. 

1 5 HARMONY 468 adds a pitch-shifted and a non pitch-shifted microphone 

signal to create the sound of two vocalists. MUTE 470 mutes the associated 
microphone. 

As described above with reference to FIG. 4, a remote control may 
enable a user to modify the flow of data to a set-top box. However, other 
20 input devices may be used. For instance, such input devices include, but are 
not limited to, a keyboard or a mouse. 

Through the use of the present invention, data may be transmitted from 
a particular network device to a requesting network device. In accordance 
with one embodiment, data is transmitted to a set-top box from a local server. 
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Of course, when a particular file is not directly accessible by the local server, 
the file may be downloaded from a central server (e.g., to a file server 
associated with the local server). In addition, data may be transmitted from 
the central server via the local server. The downloading and/or transmission 
5 from the central server to the local server may be initiated by the user (e.g., via 
a web browser) or by the local server when the file cannot be directly accessed 
by the local server. Once data flow associated with a file is initiated, the data 
flow may be modified through the sending of various control commands by 
the user (e.g., via an infra-red remote control). In accordance with one 
1 0 embodiment, data flow from the local server may be modified by the user. 
The flow of data and modification of the data flow from the local server will 
be described in further detail below with reference to FIG. 5 through FIG. 14. 
However, it will be understood that the flow of data and modification of the 
data flow may also be performed via the central server. 
15 FIG. 5 is a process flow diagram illustrating a method of playing a 

movie or karaoke selection in accordance with an embodiment of the 
invention. When the set-top box is turned on at block 502, a menu is 
displayed at block 504. For instance, a screen such as that illustrated in FIG. 
3 A may be displayed to enable a user to enter one or more karaoke or movie 
20 selections as shown in FIG. 3B. The user enters one or more selections at 
block 506 to indicate those movies, karaoke selections or other video files to 
be transmitted to the set-top box. The user then selects a control command at 
block 508 to initiate, terminate or otherwise modify the flow of data to the set- 
top box. Thus, the control command generally indicates a desired 
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modification of the flow of data to the set-top box. More particularly, this 
may be accomplished by pressing a key on a remote control such as that 
described above with reference to FIG. 4. For instance, the user may select 
the VIEW command in order to view a selected video. 

When the control command (e.g., view command) is received by the 
set-top box at block 510, the set-top box deciphers the infra red control signal 
and sends the control command to a CPU of the set-top box at block 512. The 
set-top box then sends the control command to the local server at block 514. 
The local server receives the control command at block 516. In addition, the 
local server may receive a signal indicating a current video selection. The 
local server then sends a compressed data stream over a network to the set-top 
box at block 518. More particularly, the compressed data stream may include 
audio, video and other digital data. The set-top box then processes the data 
received from the local server at block 520. One method of processing the 
data by the set-top box is described in further detail below with reference to 
FIG. 14. 

In accordance with one embodiment, the user may initiate and modify 
the transmission of karaoke data from a server to the set-top box. Thus, a first 
audio signal is received by the set-top box from a server and processed, as will 
be described below with reference to FIG. 14. In addition, the user may sing 
along with the karaoke selection through a microphone, creating a second 
audio signal. FIG. 6 is a process flow diagram illustrating a method of 
processing a user's voice input in accordance with an embodiment of the 
invention. More particularly, when a user sings through a microphone 
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connected to the set-top box at block 600, the audio signal is processed by an 
analog to digital converter at block 602. In addition, the user may select an 
audio control command as shown at block 604 via a karaoke control key as 
described above with reference to FIG. 4 to modify the audio signal that is 
5 ultimately produced by the set-top box. For instance, the user may wish to 
adjust the volume or pitch. The singer's voice is then processed by the 
karaoke processor at block 606 to modify the second audio signal. This 
modified second audio signal is then sent to a digital to analog converter at 
block 608. The resulting analog audio signal is then sent to an amplifier at 
10 block 610. 

The flow of data to the set-top box may be modified in a variety of 
ways. As described above with reference to FIG. 4, the flow of data may be 
modified in a variety of ways. For instance, the user may wish to pause a 
video, or press a remote control key such as STEP, SLOW, PLAY, MENU, 

15 NEXT, or SEEK. Exemplary process flow diagrams illustrating such possible 
modifications to the flow of data to a set-top box will be described in further 
detail below with reference to FIG. 7 through FIG. 13. 

When a user wishes to pause the transmission of data to the set-top 
box, the user may press the PAUSE button on the remote control. FIG. 7 is a 

20 process flow diagram illustrating a method of pausing a movie or karaoke 
selection in accordance with an embodiment of the invention. As shown, 
when a user selects a pause control command at block 702, the set-top box 
deciphers the infra-red control at block 704. The pause control command is 
then sent to a CPU of the set-top box at block 706. The set-top box sends the 
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pause control command to the local server at block 708. In response, as 
shown at block 710, the local server stops sending data to the set-top box until 
further instruction. 

A user may press the STEP key when he or she wishes to step the 
5 transmission of data (e.g., by a single frame). FIG. 8 is a process flow 
diagram illustrating one method of stepping transmission of data in 
accordance with an embodiment of the invention. As shown at block 802, a 
user may select the step control command through pressing the STEP key on a 
remote control. When the infra red signal is received by the set-top box, the 

10 set-top box deciphers the infra red signal at block 804 and sends a step control 
command to a CPU of the set-top box at block 806. The set-top box (e.g., 
CPU) then transmits this step control command to the local server at block 
808. In response, the local server advances the appropriate video by a frame 
by sending data associated with that frame to the set-top box at block 810. 

15 The set-top box then processes the data received from the local server at block 
812, as will be described in further detail below with reference to FIG. 14. 

A user may similarly wish to modify the speed of transmission of data 
to the set-top box over the network. For instance, the user may wish to reduce 
as well as increase the speed of data transmission. FIG. 9 is a process flow 

20 diagram illustrating one method of reducing the speed of data transmission to 
the set-top box in accordance with one embodiment of the invention. When a 
user wishes to slow the speed of data transmission, the user may press a 
SLOW key on a remote control as shown at block 902, as described above 
with reference to FIG. 4. The set-top box deciphers the infra red control at 
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block 904 and a slow control command indicating that the data transmission is 
to be slowed is sent to a CPU of the set-top box at block 906. The set-top box 
then sends the slow control command to the local server at block 908. In 
response to the control command, the local server reduces the speed with 
5 which data (e.g., frames) are sent to the set-top box at block 910. The local 
server then continues to send compressed data over the network to the set-top 
box at block 912. The set-top box then processes the data received from the 
local server at block 914, which will be described in further detail below with 
reference to FIG. 14. 

10 The user may also wish to initiate the transmission of data over the 

network to the set-top box (e.g., from a pause mode). Alternatively, the user 
may wish to resume transmission of data to a normal speed from a step or 
slow mode. FIG. 10 is a process flow diagram illustrating a method of 
initiating or resuming the transmission of data in accordance with one 

15 embodiment of the invention. As shown at block 1002, the user may select 
the play control command at block 1002. This may be accomplished through 
pressing the PLAY key on a remote control such as that illustrated in FIG. 4. 
For instance, the PLAY key may be pressed from the pause, step, or slow 
mode. The set-top box then deciphers the infra red control at block 1004 and 

20 a play control command indicating that initiation of the transmission of data is 
requested is sent to a CPU of the set-top box at block 1006. The set-top box 
then sends the play control command to the local server at block 1 008. The 
local server then initiates the transmission of data at block 1010. More 
particularly, the local server may initiate the transmission of data or simply 
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return to normal speed with which data is sent to the set-top box. The local 
server continues to send compressed data over the network to the set-top box 
at block 1012. In addition, in accordance with one embodiment, the local 
server sends a percentage value indicating a percent of the file that has been 
transmitted (e.g., percent of a movie that has been played over the network). 
The set-top box processes the data it receives from the local server at block 
1014, as will be described in further detail below with reference to FIG. 14. 
The set-top box further displays the percent of the selection that has been 
transmitted to the set-top box and therefore played for the user at block 1016. 
As described above, the data may be associated with any file, such as a movie 
or karaoke selection. 

The user may wish to edit his or her selections that have been 
previously entered via a screen such as that illustrated in FIG. 3 A and FIG. 
3B. In this manner, the user may specify via the set-top box an order of 
transmission of one or more files. The files may be of varying types, such as 
those storing movies or karaoke videos. It is important to note that the files 
being selected are not stored locally at the set-top box, but identify files stored 
in association with a remotely located server on the network. 

FIG. 1 1 is a process flow diagram illustrating a method of selecting 
data files to be transmitted via a menu in accordance with one embodiment of 
the invention. As shown, the user may select a menu control command at 
block 1 102 which sends an infra red signal to the set-top box. The set-top box 
deciphers the infra red control at block 1 104 and sends this menu control 
command to a CPU of the set-top box at block 1 106. The set-top box sends 
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this menu control command over the network to the local server at block 
1 108. The local server then stops sending compressed data over the network 
to the set-top box at block 1110. For instance, the local server may stop 
sending data until a VIEW/MENU key on a remote control such as that 
5 illustrated in FIG. 4 is toggled by the user. 

The set-top box then displays a menu of selections at block 1112. As 
one example, the menu may present the user with a number of possible files 
(e.g., movie or karaoke) to be transmitted to the set-top box. As another 
example, the menu may simply be a screen such as that presented in FIG. 3 A 

10 which may enable a user to enter as well as modify his or her selections as 
illustrated in FIG. 3B. When presented with this menu, the user may add as 
well as edit the menu selections that are displayed at block 1114. As one 
example, the user may have be presented with a screen illustrating a single 
previously entered selection. The user may then enter or select additional 

15 selections up to a maximum number of permissible selections. As another 
example, the menu may present the user with a number of selections 
previously selected by the user. The user may then modify one or more of 
these selections. 

When the user decides to view one or more of his selections, the view 
20 control command may be selected by again toggling the VIEW/MENU key at 
block 1116. The set- top box deciphers the infra-red control at block 1118 and 
a view control command is sent to a CPU of the set-top box at block 1 120. 
The set-top box sends the view control command over the network to the local 
server at block 1 122. For instance, the view control command may identify 
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one or more files to be transmitted over the network. In addition, the view 
control command may also indicate the order of transmission of those files. 
Of course, the view control command may also designate a starting point from 
which compressed data is to be transmitted. The starting point may indicate a 
5 specific file as well as a location (e.g., percentage) within that file. The local 
server then resumes sending compressed data over the network to the set-top 
box at block 1 124. The set-top box then processes the data it receives at block 
1 126, which will be described in further detail below with reference to FIG. 
14. 

10 Rather than allowing all selections to play consecutively, the user may 

wish to terminate a current video and start the next selected video. FIG. 12 is 
a process flow diagram illustrating one method of initiating the transmission 
of data associated with a next selected video in accordance with one 
embodiment of the invention. When the user wishes to stop the transmission 

15 of data associated with a first video and start the transmission of data 

associated with a second video, the user may select the next control command 
at block 1202 by pressing the NEXT key on a remote control such as that 
illustrated in FIG. 4. The set-top box deciphers the infra red control at block 
1204. A next control command indicating that a next video is selected is then 

20 sent to a CPU of the set-top box at block 1206. The set-top box sends the next 
control command to the local server indicating that the next video is selected 
as shown at block 1208. For instance, the next control command may directly 
or indirectly identify a currently selected video. At block 1210 the local 
server stops sending compressed data associated with the previous selection 
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over the network to the set-top box. The local server then sends compressed 
data associated with the current selection over the network to the set-top box 
at block 1212. The set-top box then processes the data it receives from the 
local server at block 1214. One method of processing the compressed data 
5 will be described in further detail below with reference to FIG. 14. 

When a user wishes to initiate transmission of data from a particular 
location in a file, the user may press the SEEK key of a remote control such as 
that illustrated in FIG. 4. FIG. 13 is a process flow diagram illustrating a 
method of performing a seek in accordance with an embodiment of the 
10 invention. As shown at block 1302 the user may select the seek control 

command by pressing the SEEK key of a remote control at block 1302. In 
addition, the user indicates a location in the video file from which data 
transmission is desired at block 1304. In accordance with one embodiment, 
the user selects a percentage of a video file that has been transmitted. The set- 
1 5 top box deciphers the infra red control at block 1306 and the corresponding 
seek control command indicating the desired percentage is sent to a CPU of 
the set-top box at block 1308. 

In accordance with one embodiment, the starting point in the file from 
which data is to be transmitted is calculated by the set-top box. More 
20 particularly, when the file is initially selected, the local server sends 

information associated with the file such as the size of the file to the set-top 
box. For instance, when an MPEG file is transmitted, file information is 
transmitted in the initial packets that are transmitted. The set-top box uses the 
size of the file and the percentage to determine a starting point in the file at 
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block 1310. The set-top box then sends an indicator of the desired file 
location to the local server at block 1312. 

Alternatively, the calculation of the starting point may be performed 
by the local server. In accordance with this embodiment, the set-top box 

5 sends the seek control command indicating the desired percentage over the 
network to the local server at block 1310. When the local server receives the 
seek control command, the local server uses the size of the file and the 
percentage to determine a starting point in the file at block 1312. 

The local server then "jumps" to this starting point in the file at block 

10 1314 and initiates the transmission of compressed data from the starting point 
over the network to the set-top box at block 1316. The set-top box then 
processes the data it receives from the local server at block 1318, which will 
be described in further detail below with reference to FIG. 14. 

As described above, when the set-top box receives compressed data 

15 sent over the network, the set-top box processes this data. FIG. 14 is a process 
flow diagram illustrating one method of processing data received by the set- 
top box in accordance with one embodiment of the invention. A variety of 
commands sent by the set-top box result in compressed video data being sent 
to a requesting client (e.g., set-top box). When the client sends a request to a 

20 server asking the server to send compressed video data to the client, the server 
splits the associated compressed video data file (or portion thereof) into 
multiple packets and sends the packets to the client. As shown at block 1402 
the set-top box receives the compressed video data from the local server. An 
MPEG decoder chip then decompresses video and audio data in the 
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compressed data at block 1404. The decompressed video signal is then sent to 
a video encoder to convert the digital signal to an analog signal at block 1406. 
The resulting analog signal is then output to a television or monitor at block 
1408. The data received by the set-top box may be stored for future use. 
5 However, it may be desirable to delete the data once it is provided by the set- 
top box to the user. In this manner, a video may be displayed in real-time 
onto a television screen. 

In addition to the decompressed video data, the decompressed audio 
data is also processed by the set-top box. More particularly, in accordance 

10 with the karaoke embodiment, the decompressed audio signal is sent to the 
karaoke processor at block 1410. The processed audio signal is then sent to a 
digital to analog converter at block 1412, The resulting analog audio signal is 
then sent to an amplifier at block 1414. 

When data is transmitted from the central server to the set-top box via 

15 a local server, the local server may store a copy of this data (e.g., in an 

associated file server). Alternatively, it may be desirable to erase this copy 
once the data is transmitted to a requesting set-top box. 

The present invention may be used in a variety of environments. For 
instance, the above-described system may be configured as a networked 

20 karaoke system to enable a plurality of rooms to access karaoke songs 
concurrently without the intervention of a human operator. The present 
invention may also be used to provide hotels a cost-effective solution to 
deliver movies to hotel guests. Moreover, it may also be useful in hospitals to 
enable bed-ridden patients to watch movies or surf the Internet. Schools may 
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also implement the present invention within a campus local area network to 
transmit video-taped lectures or other presentations. Additionally, long trips 
in a confined seat takes a toll on passengers in a common carrier such as an 
airplane, cruise ship, train or bus. Thus, the present invention may allow each 
passenger to watch and control a movie he or she is interested in throughout 
the entire trip. It may also be desirable to implement the present invention 
within an apartment complex to enable the system as well as system costs to 
be shared by each residential unit. Additionally, the present invention may be 
deployed as a video kiosk in airports, train stations, hotel lobbies, department 
stores, conventions, or museums for information, catalog or advertisement 
purposes. 

The emergence of the Internet has created a world-wide data network. 
As Internet traffic grows steadily, the data highway's bandwidth increases 
accordingly. This presents a major opportunity for a new class of dedicated 
communication devices that will allow users to conduct communication (e.g., 
via voice and video data) through the data network. This information 
exchange has evolved from text-based to graphics-based to content-rich, 
video-based communications capable of providing a multitude of services. 
Accordingly, the present invention may be implemented in a device or web 
browser to provide interactive, real-time, high-bandwidth services to a user 
using the Internet. 

As described above, the present invention enables a client device such 
as a set-top box to receive data streams such as video streams that are 
transported over a network from a video server. In addition, the set-top box 
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might output information to the network in the course of performing the 
above-described method steps. Such information may be received from and 
outputted to the network, for example, in the form of a computer data signal 
embodied in a carrier wave. The network may also be a wireless network. 
5 Through the use of the present invention, video, audio, and karaoke 

functionality are integrated in a single system capable of interfacing to a 
standard television. Since the present invention is implemented in a set-top 
box, it is compact and portable. Moreover, since a computer system is not 
required, the present invention may be manufactured at a relatively low cost to 
10 the consumer. 

Although illustrative embodiments and applications of this invention 
are shown and described herein, many variations and modifications are 
possible which remain within the concept, scope, and spirit of the invention, 
and these variations would become clear to those of ordinary skill in the art 
1 5 after perusal of this application. For instance, the present invention is 
described as transmitting data from a local server within the context of a 
digital television receiver. However, the present invention may be used in 
other contexts, such as through transmitting data from another server (e.g., 
central server) via the local server. For instance, the present invention may 
20 permit access to a central server on the Internet. Similarly, the present 

invention may be implemented across a plurality of staged servers, enabling 
information to be transmitted across the Internet. Moreover, the above 
described process blocks are illustrative only. Therefore, the present invention 
may be performed using alternate process blocks as well as alternate data 
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structures. Accordingly, the present embodiments are to be considered as 
illustrative and not restrictive, and the invention is not to be limited to the 
details given herein, but may be modified within the scope and equivalents of 
the appended claims. 
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Patent 



Claims 



What is claimed is: 



1 . In a network including a local server coupled to a central server, the 
local server being coupled to a plurality of network devices, a method of 
interactively controlling from one of the plurality of network devices a flow of 
audio visual data from the central server to the network device, the method 
comprising: 

obtaining a control command at the network device, the control 
command indicating a desired modification to the flow of the audio visual 
data from the central server to the network device; 

sending the control command from the network device to the central 
server via the local server; and 

receiving a modified flow of the audio visual data from the central 
server at the network device in response to the control command. 



2. In a network including a local server coupled to a central server, the 
local server being coupled to a plurality of network devices, a method of 
interactively controlling from one of the plurality of network devices a flow of 
audio visual data from the central server to the network device, the method 
comprising: 

obtaining a control command at the network device, the control 
command indicating a desired modification to the flow of the audio visual 
data from the central server to the network device; 

sending the control command from the network device to the central 
server via the local server; and 

modifying the flow of the audio visual data from the central server to 
the network device in response to the control command. 
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3. The method as recited in claim 2, wherein modifying the flow of the 
audio visual data from the central server to the network device in response to 
the control command comprises: 
5 modifying the flow of the audio visual data from the central server to 

the local server; and 

when modifying the flow of the audio visual data from the central 
server to the local server includes sending a compressed audio visual data 
stream to the local server, sending the compressed audio visual data stream to 
1 0 the network device. 



4. The method as recited in claim 3, further comprising: 

prior to sending the compressed audio visual data stream to the 
network device, storing the compressed audio visual data stream in a memory 
15 associated with the local server. 



5. The method as recited in claim 3, wherein sending the compressed 
audio visual data stream to the network device is performed in real time. 



20 



6. In a network including a local server coupled to a central server, the 
local server being coupled to a plurality of network devices, a method of 
interactively controlling from one of the plurality of network devices a flow of 
25 audio visual data from the central server to the network device, the method 
comprising: 

receiving a control command at the central server from one of the 
plurality of network devices, the control command indicating a desired 
modification to the flow of the audio visual data from the central server to the 
30 network device; and 

modifying the flow of the audio visual data from the central server to 
the local server in response to the control command, thereby enabling the flow 
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of audio visual data from the central server to the network device to be 
interactively controlled by the network device. 

7. In a network including a local server coupled to a central server, the 
local server being coupled to a plurality of network devices, a method of 
transmitting a audio visual data stream from the central server to one of the 
plurality of network devices, the method comprising: 

receiving a control command from one of the plurality of network 
devices, the control command indicating a desired modification to the audio 
visual data stream being transmitted from the central server to the one of the 
plurality of network devices via the local server; and 

sending a modified audio visual data stream from the central server to 
the local server in response to the control command, thereby enabling a audio 
visual data stream being transmitted from the central server to the network 
device to be interactively controlled from the network device. 

8. In a network including a local server coupled to a central server, the 
local server being coupled to a plurality of network devices, a method of 
interactively controlling from one of the plurality of network devices a flow of 
audio visual data from the central server to the network device, the method 
comprising: 

receiving a control command at the local server from the network 
device, the control command indicating a desired modification to the flow of 
the audio visual data from the central server to the network device; 

sending the control command to the central server; 

receiving a modified audio visual data flow from the central server in 
response to the control command; and 

transmitting the modified audio visual data flow from the local server 
to the network device, thereby enabling the network device to modify the flow 
of the audio visual data from the central server to the network device. 
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9. The method as recited in claim 8, further comprising: 
determining whether a file associated with the control command is 

stored in a memory associated with the local server; and 

performing the sending and receiving steps when the file associated 
with the control command is not stored in the memory associated with the 
local server. 

10. The method as recited in claim 8, further comprising: 

prior to sending the modified audio visual data flow from the local 
server to the network device, storing the modified audio visual data flow in a 
memory associated with the local server. 

1 1 . The method as recited in claim 8, wherein the modified audio visual 
data flow is associated with a first file that is different from a second file 
associated with the audio visual data that is sent from the central server to the 
network device. 

12. The method as recited in claim 8, wherein the modified audio visual 
data flow is sent from the local server to the network device at a speed 
identical to that of the modified audio visual data flow received from the 
central server. 

13. The method as recited in claim 8, wherein the modified audio visual 
data flow is received by the local server at a speed that is different from a 
speed of the flow of the audio visual data from the central server to the 
network device prior to sending the control command to the central server. 

14. The method as recited in claim 8, wherein the modified audio visual 
data flow is initiated at a first point in a file that is different from a second 
point in the file at which the control command is received at the local server 
during the flow of the audio visual data. 
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15. The method as recited in claim 8, the audio visual data is associated 
with a first file and the modified audio visual data flow is associated with a 

5 second file. 

16. The method as recited in claim 15, wherein the first file is different 
from the second file. 

10 

17. The method as recited in claim 15, wherein the first file identical to the 
second file. 

18. The method as recited in claim 13, wherein the first file is a movie file 
15 or a karaoke file and the second file is a movie file or a karaoke file. 

19. In a network including a local server coupled to a central server, the 
local server being coupled to a plurality of network devices, a method of 

20 interactively controlling from one of the plurality of network devices a flow of 
audio visual data from the central server to the network device, the local 
server having a memory associated therewith, the method comprising: 

receiving a control command at the local server from the network 
device, the control command indicating a desired initiation of audio visual 
25 data flow associated with a specified file; 

determining whether the specified file is stored in the memory 
associated with the local server; and 

when it is determined that the specified file is not stored in the memory 
associated with the local server, sending the control command to the central 
30 server. 
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20. The method as recited in claim 19, further comprising: 

when it is determined that the specified file is not stored in the memory 
associated with the local server, receiving an audio visual data stream from the 
central server in response to the control command and sending the audio 
visual data stream from the local server to the network device. 

21 . The method as recited in claim 19, further comprising: 
receiving an audio visual data stream from the central server at the 

local server in response to the control command; and 

sending the audio visual data stream from the local server to the 
network device. 

22. The method as recited in claim 20, further comprising: 

when it is determined that the specified file is not stored in the memory 
associated with the local server, storing the audio visual data stream in a file in 
the memory associated with the local server. 



23 . The method as recited in claim 1 9, further comprising: 

receiving compressed data associated with the specified file from the 
central server at the local server in response to the control command; and 
storing the specified file in the memory associated with the local 

server. 

24. In a local server, the local server being coupled to a central server in a 
network, the local server being coupled to a plurality of network devices, a 
method of interactively controlling from one of the plurality of network 
devices a flow of audio visual data from the central server to the network 
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device, the local server having a memory associated therewith, the method 
comprising: 

receiving a control command at the local server from the network 
device, the control command indicating a desired initiation of data flow 
5 associated with a specified file; 

sending the control command to the central server; 
receiving an audio visual data stream from the central server at the 
local server in response to the control command; and 

transmitting the audio visual data stream from the local server to the 
1 0 network device. 



25. The method as recited in claim 24, further comprising: 

storing the audio visual data stream in the memory associated with the 
15 local server. 



26. A central server adapted for being coupled to a local server, the local 
20 server being coupled to a plurality of network devices, the central server being 
adapted for transmitting a audio visual data stream from the central server to 
one or more of the plurality of network devices via the local server, 
comprising: 

a processor; and 

25 a memory, the memory storing therein instructions for: 

receiving a control command from one of the plurality of 
network devices, the control command indicating a desired 
modification to the audio visual data stream being transmitted from the 
central server to the one of the plurality of network devices via the 
30 local server; and 

sending a modified audio visual data stream from the central 
server to the network device via the local server in response to the 
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control command, thereby enabling an audio visual data stream being 
transmitted from the central server to the network device to be 
interactively controlled from the network device. 



5 

27. A local server adapted for being coupled to a central server and to a 
plurality of network devices, the local server being configured for 
interactively controlling a flow of audio visual data from the central server to 
one of the plurality of network devices, comprising: 
10 a processor; and 

a memory storing therein the following instructions: 

instructions for receiving a control command at the local server 
from the network device, the control command indicating a desired 
modification to the flow of the audio visual data from the central 
1 5 server to the network device; 

instructions for sending the control command to the central 

server; 

instructions for receiving a modified audio visual data flow 
from the central server in response to the control command; and 
20 instructions for transmitting the modified audio visual data 

flow from the local server to the network device, thereby enabling the 
network device to modify the flow of the audio visual data from the 
central server to the network device. 

25 28 . The local server as recited in claim 27, the memory further comprising: 
instructions for determining whether a file associated with the control 
command is stored in a memory associated with the local server; and 

instructions for performing the sending and receiving steps when the 
file associated with the control command is not stored in the memory 
30 associated with the local server. 
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29. A local server coupled to a central server, the local server being 
coupled to a plurality of network devices, the local server being adapted for 

5 interactively controlling from one of the plurality of network devices a flow of 
audio visual data to the network device, comprising: 
a processor; and 

a memory, the memory storing therein the following instructions: 
instructions for receiving a control command at the local server from 
10 the network device, the control command requesting an initiation of audio 
visual data flow associated with a specified file; 

instructions for determining whether the specified file is stored in a 
memory associated with the local server; and 

instructions for sending the control command to the central server 
1 5 when it is determined that the specified file is not stored in the memory 
associated with the local server. 

30. The local server as recited in claim 29, the memory further comprising: 
instructions for receiving an audio visual data stream from the central 

20 server in response to the control command and sending the audio visual data 
stream from the local server to the network device. 



25 31. The local server as recited in claim 30, the memory further comprising: 
instructions for storing the audio visual data stream in a file in the 
memory associated with the local server. 



30 32. A system for enabling a continuous stream of audio visual data to be 
sent to a network device, comprising: 
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a central server having a memory associated therewith, the memory 
having stored therein a plurality of files; 

a local server coupled to the central server and having a memory 
associated therewith, the local server configured to obtain a file from the 
5 central server when the file that is requested is not stored in the memory 
associated with the local server; and 

a plurality of network devices coupled to the local server, each of the 
plurality of network devices being configured for sending a file request to the 
local server, the file request indicating a request for audio visual data 
1 0 associated with a requested file. 



33. The system as recited in claim 32, further comprising: 
a memory associated with the local server; 
1 5 wherein the local server is configured to store the file in the memory 

when the file is obtained from the central server. 



34. The system as recited in claim 33, wherein the local server is 
20 configured to transmit an audio visual data stream associated with the file to 
one of the plurality of network devices when the file is obtained from the 
central server in response to the file request received from the one of the 
plurality of network devices. 

25 35. The system as recited in claim 32, wherein the local server is 

configured to transmit an audio visual data stream associated with the file to 
one of the plurality of network devices when the file is obtained from the 
central server in response to the file request received from the one of the 
plurality of network devices. 
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36. The system as recited in claim 35, wherein the central server is 
configured to transmit a modified audio visual data stream in response to a 
control command received from the one of the plurality of network devices 
and wherein each of the plurality of network devices is configured to send a 

5 control command indicating a desired modification to the audio visual data 
stream being transmitted to the corresponding network device. 

37. A local server adapted for being coupled to a central server and a 

1 0 plurality of network devices, the local server being configured to interactively 
control from one of the plurality of network devices a flow of audio visual 
data from the central server to one of the plurality of network devices, 
comprising: 

a processor; and 

15 a memory associated therewith, the memory storing therein the 

following instructions: 

instructions for receiving a first control command at the local server 

from the network device, the first control command indicating a desired 

initiation of data flow associated with a specified file; 
20 instructions for forwarding the first control command to the central 

server; 

instructions for receiving an audio visual data stream from the central 
server at the local server in response to the first control command; 

instructions for transmitting the audio visual data stream from the local 
25 server to the network device; 

instructions for receiving a second control command at the local server 
from the network device, the second control command indicating a desired 
modification of data flow; 

instructions for forwarding the second control command to the central 

30 server; 
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instructions for receiving a modified audio visual data stream from the 
central server at the local server in response to the second control command; 
and 

instructions for transmitting the modified audio visual data stream 
5 from the local server to the network device. 



38. The local server as recited in claim 37, the memory further comprising: 
10 instructions for storing the first audio visual data stream in the memory 

associated with the local server. 

39. The local server as recited in claim 37, wherein the specified file is a 
15 karaoke file. 

40. The local server as recited in claim 37, wherein the specified file is a 
movie file. 

20 

41 . A network device adapted for being coupled to a network including a 
local server coupled to a central server, the local server adapted for being 
coupled to a plurality of network devices, the network device being adapted 

25 for interactively controlling a flow of audio visual data from the central server 
to the network device, comprising: 
a processor; and 

a memory, at least one of the processor and the memory being adapted 

for: 

30 obtaining a control command at the network device, the control 

command indicating a desired modification to the flow of the audio 
visual data from the central server to the network device; 
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sending the control command from the network device to the 
central server via the local server; and 

receiving a modified flow of the audio visual data from the 
central server at the network device in response to the control 
command. 



42. A computer-readable medium adapted for interactively controlling 
from a network device a flow of audio visual data from a central server to the 
network device, the central server being connected to the network device via a 
local server adapted for being coupled to a plurality of network devices, 
comprising: 

instructions for receiving a control command from the network device, 
the control command indicating a desired initiation of data flow associated 
with a specified file; 

instructions for connecting to the central server via the Internet; 

instructions for sending the control command to the central server; and 

instructions for receiving an audio visual data stream transmitted from 
the central server via the local server in response to the control command. 

43. The computer-readable medium as recited in claim 42, further 
comprising: 

instructions for transmitting the audio visual data stream to the 
network device, 

44. The computer-readable medium as recited in claim 42, further 
comprising: 

instructions for requesting that the specified file be downloaded to the 
local server. 

Attorney Docket No. NEV1P002/SDB/ERH PATENT 

47 



45. The computer-readable medium as recited in claim 42, wherein the 
specified file is a karaoke file. 

5 46. The computer-readable medium as recited in claim 42, wherein the 
specified file is a movie file. 

47. A computer-readable medium adapted for interactively controlling 
from a network device a flow of audio visual data from a central server to the 

10 network device, the central server being connected to the network device via a 
local server adapted for being coupled to a plurality of network devices, 
comprising: 

instructions for connecting to the central server via the Internet; 

instructions for receiving a control command from the network device, 
1 5 the control command requesting that a specified file be downloaded from the 
central server to the local server, thereby enabling transmission of audio visual 
data associated with the specified file to be controlled at the local server by the 
network device; and 

instructions for sending the control command to the central server. 

20 

48. The computer-readable medium as recited in claim 47, further 
comprising: 

instructions for selecting the specified file from one of a plurality of 
files stored in a memory associated with the central server. 

25 

49. The computer-readable medium as recited in claim 47, wherein the 
specified file is a karaoke file. 

50. The computer-readable medium as recited in claim 47, wherein the 
30 specified file is a movie file. 
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INTERACTIVE DATA TRANSMISSION 
SYSTEM HAVING STAGED SERVERS 

5 



Abstract of the disclosure 

Methods and apparatus for use in a network including a local server 
coupled to a central server, the local server being coupled to a plurality of 

10 network devices, for interactively controlling from one of the plurality of 
network devices a flow of audio visual data from the central server to the 
network device, comprising obtaining a control command at the network 
device, the control command indicating a desired modification to the flow of 
the audio visual data from the central server to the network device. The 

1 5 control command is sent from the network device to the central server via the 
local server. A modified flow of the audio visual data is then received from 
the central server at the network device in response to the control command. 
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IR REMOTE CONTROL INSTRUCTIONS 



The following diagram is the IR remote control key positions. 
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NTSC/PAL] - Switches between NTSC and PAL mode. Default is PAL mode after power-up 



Resetj - Reboots the set-top box. 



Nextj - Stops the current video and starts the next video selected. 



Entei) - Press enter to change from karaoke to movie and vice versa. 
Press enter to erase title 0. 

Press enter after entering karaoke or movie title is completed. 



VlewlMenu\ - After all karaoke or movie titles are entered, press this key to start playing 
video. 

During video play, when this key is pressed, menu screen would come on and video titles 
can be added or edited. Press this key again to start playing the video. 



JJp/Down/Right/Lefq arrow keys - Moves the cursor (indicated by gold color) up or down, 

right or left. 



O-Vl number keys - Numbers are used to identify video titles. 



Turn on set-top 
box 



Display menu 



User selects one 
or more video/ 
karaoke selections 



User selects 
control command 
(e.g., view) 



Set-top box 
deciphers infra red 
control 



Control command 

(e.g., view 
command) sent to 
CPU of set-top box 



-SV2, 



Set-top box sends 

view control 
command to local 
server 



•si 4 



Local server 
receives signal 

indicating 
selection and 
control command 
(e.g., view) 



Local server sends 

compressed 
karaoke/video data 
over network to 
set-top box 



FIG. 5 



Set-top box 
processes data 
from local server 



ser sings througm 
microphone J 



User sings through 

microphone 
connected to set- 
top box 



Send second 
audio signal to A/D 
converter 



User selects audio 
control command 

(e.g., volume, 
echo, fader, pitch, 
harmony) 



singers voice is 
processed by 
karaoke processor 

to create a 
modified second 
audio signal 



40U 



Send modified 
second audio 
signal to D/A 
converter 



-OAT 



Send anlog audio 
signal to amplifier 



FIG. 6 



User pauses 



User selects 
pause control 
command 



Set-top box 
deciphers infra red 
control 



Pause control sent 
to CPU of set-top 
box 



Set-top box sends 

pause control 
command to local 
server 



Local server stops 
sending data to 
set-top box until 

further instruction 



FIG. 7 



User selects step ) 



User selects step 
control command 



•PL 



Set-top box 
deciphers infra red 
control 



Step control sent 
to CPU of set-top 
box 



Set-top box sends 

step control 
command to local 
server 



Local server 
advances video by 

one frame by 
sending frame 
data to set-top box 



Set-top box 
processes data 
from local server 



User selects slow 



User selects slow 
control command 



Set-top box 
deciphers infra red 
control 



Slow control sent 
to CPU of set-top 
box 



Set-top box sends 

slow control 
command to local 
server 



Local server slows 
speed with which 
frames are sent to 
set-top box 



Local server 
continues to send 
compressed data 
over network to 
set-top box 



Set-top box 
processes data 
from local server 



FIG. 9 



/User selects pla^\ 
f from pause, step, j 
V or slow mode^ / 



User selects play 
control command 



Set-top box 
deciphers infra red 
control 



Play control sent 
to CPU of set-top 
box 



Nook 



Set-top box sends 

play control 
command to local 
server 



Local server 
returns to normal 
speed with which 
frames are sent to 

set-top box 



Local server 
continues to send 
compressed data 
over network to 
set-top box 




Set-top box 
processes data 
from local server 



Display percent 
video/karaoke 
selection played 



FIG. 10 



Iser selects menir 
option j 



User selects menu 
control command 



Set-top box 
deciphers infra red 
control 



Menu control sent 
to CPU of set-top 
box 



HI* 



Set-top box sends 

menu control 
command to local 
server 



Local server stops sending 

compressed data over 
network to set-top box until 
VIEW/MENU key is toggled 



Set-top box 
displays menu of 
selections 



■mi 



User optionally 
adds/edits menu 
selections 



User toggles 
ViEW/MENU key 

-ID iter 

* 'ijJJL 




-A 



Set-top box 
deciphers infra-red 
control 



View control sent 
to CPU of set-top 
box 



12© 



Set-top box sends 

view control 
command to local 
server 



mi 



Local server 
continues to send 
compressed data 
over network to 
set-top box 



Set-top box 
processes data 
from local server 



AYLH 



1:4 



User select s nex y 



User selects next 
control command 



Set-top box 
deciphers infra red 
control 



Next control sent 
to CPU of set-top 
box 



Set-top box sends 

next control 
command to local 
server indicating 
next selection 



Mot 



Local server stops 
sending compressed 
data associated with 
previous selection over 
network to set-top box 



Local server sends 
compressed data 
associated with 
current selection 
over network to 
set-top box 



Set-top box 
processes data 
from local server 



nil 



C S6£ PIC , 



FIG. 12 



User selects seek 



User selects seek 
control command 



User seiects 
percentage of 
selection to jump 
to 



30M 



Set-top box 
deciphers infra red 
control 



Seek control with 
the percentage 
sent to CPU of 
set-top box 



Zed 



Set-top box 
calculates starting 
point using file 
size and the 
percentage 



-i?)t> 



Set-top box sends 
an indicator of the 
starting point to" 
the local server 



H\7 



Local server jumps 
to the starting 
point in file 



Local server sends 
compressed data 
from the starting 
point over network 
to set-top box 



Set-top box ( 
processes data 
from local server 



BIS FIG. 



C Set-top box X 
processes data ) 
rom local servej x 



Set-top box 
receives 
compressed data 
from local server 



MPbU decoder 

chip 
decompresses 
video and audio 

data in the 
compressed data 



Send decompressed video 
signal to video encoder to 
convert digital signal to 
analog signal 



Send 
decompressed 
first audio signal to 
karaoke processor 



Output analog 
signal to TV/ 
monitor 



Send processed 
first audio signal to 
D/A converter 



FIG. 14 



Send analog audio 
signal to amplifier 



DECLARATION AND POWER OF ATTORNEY 
FOR ORIGINAL U.S. PATENT APPLICATION 



Attorney's Docket No. NEV1P002 

As a below-named inventor, I hereby declare that: 

My residence, post office address and citizenship are as stated below next to my name. 

I believe that I am the original, first and sole inventor (if only one name is listed below) or an original, first and joint inventor (if 
plural names are listed below) of the subject matter which is claimed and for which a patent is sought on the invention entitled: 
INTERACTIVE DATA TRANSMISSION SYSTEM HAVING STAGED SERVERS the specification of which, 



(check one) 1. is attached hereto. 



2. Q was filed on as 

U.S. Application No. 

and was amended on , . 

G 3. Q was filed on as 

^3 International PCT Application No. 

Eft and was amended on : 

5 hereby state that I have reviewed and understand the contents of the above-identified specification, including the claims, as 
|gmended by any amendment referred to above. 

f| acknowledge the duty to disclose information which is material to the examination of this application in accordance with Title 
Jl, CFR§ 1.56. 

Lifrior Foreign Application(s) 

^hereby claim foreign priority benefits under Title 35, United States code, § 119(a)-(d) or § 365(b) of any foreign application(s) 
^jpr patent or inventor's certificate, or § 365(a) of any PCT International application which designated at least one country other 
liian the United States, listed below and have identified below, by checking the box, any foreign application for patent or 
Coventor's certificate, or PCT International application having a filing date before that of the application on which priority is 
claimed: 

Priority Benefits Claimed? 

Yes No 

(Application No.) (Country) (Filing Date) 

Yes No 

(Application No.) (Country) (Filing Date) 

Provisional Application(s) 

I hereby claim the benefit under 35 U.S.C. §1 19(e) of any United States provisional application(s) listed below: 

60/216,797 „ July 7, 2000 

(Application No.) (Filing Date) 



(Application No.) (Filing Date) 
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Prior U.S. Application^) 



I hereby claim the benefit under Title 35, United States Code, § 120 of any United States application(s), or § 365(c) of any PCT 
International application designating the United States, listed below and, insofar as the subject matter of each of the claims of this 
application is not disclosed in the prior United States or PCT International application in the manner provided by the first 
paragraph of Title 35, United States Code, § 112, I acknowledge the duty to disclose information which is material to 
patentability as defined in Title 37, Code of Federal Regulations, § 1.56 which became available between the filing date of the 
prior application and the national or PCT international filing date of this application: 



(Application No.) (Filing Date) (Status - patented, pending, abandoned) 



(Application No.) (Filing Date) (Status - patented, pending, abandoned) 

Power of Attorney 

And I hereby appoint the law firm of Beyer Weaver & Thomas, LLP and all practitioners who are associated with the Customer 
Number 022434 as my principal attorneys to prosecute this application and to transact all business in the Patent and Trademark 
Office connected therewith. 

4)irect Correspondence To: Customer Number: 022434 

%Q BEYER WEAVER & THOMAS, LLP 

f 0 P.O. Box 778 

Berkeley, CA 94704-0778 



i prect Telephone Calls To: Attorney Name at telephone number (510) 843-6200 

A hereby declare that all statements made herein of my own knowledge are true and that all statements made on information and 
[belief are believed to be true; and further that these statements were made with the knowledge that willful false statements and the 
fSke so made are punishable by fine or imprisonment, or both, under section 1001 of Title 18 of the United States Code, and that 
Jluch willful false statements may jeopardize the validity of the application or any patent issuing thereon. 



Citizenship: United States of America 
Date of Signature: to /lV 

Residence: (City) San Jose (State/Country) California 

Post Office Address: 1858 St. Andrews Place, San Jose, California 95132 



nil 



22434 

PATENT TRADEMARK OFFICE 



^Typewritten Full Name of 
k 4olc or First Inventor: Hensen Mpu 




Inventor's signature: v ^ — ^ m 
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